# Midterm Exam

(October 18th @ 5:30 pm)

Presentation and clarity are very important! Show your procedure!

# **PROBLEM 1 (20 PTS)**

a) Complete the following table. The decimal numbers are unsigned: (5 pts.)

| Decimal | BCD          | Binary  | Reflective Gray Code |
|---------|--------------|---------|----------------------|
|         |              |         | 110111               |
|         | 000101100010 |         |                      |
|         |              | 1000101 |                      |

b) Complete the following table. Use the fewest number of bits in each case: (12 pts.)

| REPRESENTATION |                    |                |                |  |
|----------------|--------------------|----------------|----------------|--|
| Decimal        | Sign-and-magnitude | 1's complement | 2's complement |  |
| -63            |                    |                |                |  |
|                |                    |                | 10000          |  |
|                |                    | 10100          |                |  |
|                |                    |                | 011101         |  |
|                | 1100000            |                |                |  |
|                |                    | 11111          |                |  |

c) Convert the following decimal numbers to their 2's complement representations. (3 pts)  $\checkmark$  17.875

# PROBLEM 2 (15 PTS)

• Complete the timing diagram of the circuit shown below.  $y = y_3y_2y_1y_0$ ,  $x = x_1x_0$ ,  $s = s_1s_0$ 



# PROBLEM 3 (17 PTS)

- a) Perform the following additions and subtractions of the following unsigned integers. Use the fewest number of bits n to represent both operators. Indicate every carry (or borrow) from  $c_0$  to  $c_n$  (or  $b_0$  to  $b_n$ ). For the addition, determine whether there is an overflow. For the subtraction, determine whether we need to keep borrowing from a higher byte. (6 pts)  $\checkmark$  51 + 15
- b) Perform the following operations, where numbers are represented in 2's complement. Indicate every carry from  $c_0$  to  $c_n$ . For each case, use the fewest number of bits to represent the summands and the result so that overflow is avoided. (8 pts)  $\checkmark$  -61 -18
- c) Perform binary multiplication of the following numbers that are represented in 2's complement arithmetic with 4 bits. (3 pts)

1

#### PROBLEM 4 (10 PTS)

- The figure below depicts the entire memory space of a microprocessor. Each memory address occupies one byte. 1KB = 2<sup>10</sup> bytes, 1MB = 2<sup>20</sup> bytes, 1GB = 2<sup>30</sup> bytes
  - ✓ What is the size (in bytes, KB, or MB) of the memory space? What is the address bus size of the microprocessor? (2 pts.)
  - ✓ If we have a memory chip of 128 KB, how many bits do we require to address those 128 KB of memory? (1 pt.)
  - ✓ We want to connect the 128 KB memory chip to the microprocessor. For optimal implementation, we must place those 128 KB in an address range where every address shares some MSBs. Provide a list of all the possible address ranges that the 128 KB memory chip can occupy. You can only use the non-occupied portions of the memory space as shown below.



# **PROBLEM 5 (10 PTS)**

■ Sketch the circuit that computes  $|A - B| \times 4$ , where A, B are 4-bit <u>unsigned</u> numbers. For example:  $A = 0101, B = 1101 \rightarrow |A - B| \times 4 = 8 \times 4 = 32$ . You can only use full adders and logic gates. Your circuit must avoid overflow.

### PROBLEM 6 (16 PTS)

- We want to design a circuit that verifies the logical operation of a 3-input NAND gate. f = 1 (LED ON) if the NAND gate does NOT work properly (Assumption: when the NAND gate is not working, it generates 1's instead of 0's and vice versa).
  - ✓ Provide the Boolean equation for f and sketch the circuit using logic gates. (4 pts.)
  - ✓ Implement the circuit using <u>ONLY</u> 2-to-1 MUXs (AND, OR, NOT, XOR gates are not allowed). (12 pts)



## PROBLEM 7 (12 PTS)

• Complete the timing diagram of the following circuit. The VHDL code (tst.vhd) corresponds to the shaded circuit.



2

Instructor: Daniel Llamocca